package com.aqie.medium.stack;

import java.util.Stack;

/**
 * 739 等待多久温度才会升高
 */
public class DailyTemperatures {
    public int[] dailyTemperatures(int[] T) {
        int[] res = new int[T.length];
        // 单调栈 (非递增)
        Stack<Integer> stack = new Stack<>();
        // 倒序遍历
        for (int i = T.length-1; i >= 0; i--){
            // 当前元素比栈顶元素大,则调整栈使其满足递减
            while (!stack.isEmpty() && T[i] >= T[stack.peek()]){
                stack.pop();
            }
            /**
             * 栈为空, 后面没有比当前温度高
             * 不为空， 栈顶元素下标减去当前下标即为经过几天后温度比当前 温度高
             */
            res[i] = stack.isEmpty() ? 0 : stack.peek() - i;
            stack.push(i);
        }
        return res;
    }
}
